import { createApp } from "vue";

import Cookies from "js-cookie";

import ElementPlus from "element-plus";
import locale from "element-plus/lib/locale/lang/zh-cn"; // 中文语言
import Schema from "async-validator";
import "@/assets/styles/index.scss"; // global css
import "../lib/vform/designer.style.css"; //引入VFormRender样式
import VForm3 from "@/../lib/vform/designer.umd.js"; //引入VForm3库
import App from "./App";
import store from "./store";
import router from "./router";
import directive from "./directive"; // directive
import "vue-sweet-calendar/dist/SweetCalendar.css";
// import { WebControl } from "../public/jsWebControl-1.0.0.min";
// 注册指令
import plugins from "./plugins"; // plugins
import { download, download2 } from "@/utils/request";
import { downLoadFile } from "./api/common";
// svg图标
import "virtual:svg-icons-register";
import SvgIcon from "@/components/SvgIcon";
import elementIcons from "@/components/SvgIcon/svgicon";

import "./permission"; // permission control
import { useDict } from "@/utils/dict";
import {
  parseTime,
  resetForm,
  addDateRange,
  handleTree,
  selectDictLabel,
  selectDictLabels,
} from "@/utils/ruoyi";

// 分页组件
import Pagination from "@/components/Pagination";
// 自定义表格工具组件
import RightToolbar from "@/components/RightToolbar";
// 文件上传组件
import FileUpload from "@/components/FileUpload";
// 图片上传组件
import ImageUpload from "@/components/ImageUpload";
// 图片预览组件
import ImagePreview from "@/components/ImagePreview";
// 自定义树选择组件
import TreeSelect from "@/components/TreeSelect";
// 字典标签组件
import DictTag from "@/components/DictTag";
import VueVideoPlayer from "vue-video-player";
import "video.js/dist/video-js.css";
import { ElTableColumn } from "element-plus";
window.downLoadFile = downLoadFile;
const TableColumnProps = ElTableColumn.props;
// 修改默认props
// 全局el-table设置
// 全局el-table-column设置
// TableColumnProps.align = { type: String, default: "center" }; // 居中
TableColumnProps.showOverflowTooltip = { type: Boolean, default: true }; // 文本溢出
// window.WebControl = WebControl;
Schema.messages.required = (fieldName) => {
  return "字段值不可为空";
};

const app = createApp(App);

// 全局方法挂载
app.config.globalProperties.useDict = useDict;
app.config.globalProperties.download = download;
app.config.globalProperties.download2 = download2;
app.config.globalProperties.parseTime = parseTime;
app.config.globalProperties.resetForm = resetForm;
app.config.globalProperties.handleTree = handleTree;
app.config.globalProperties.addDateRange = addDateRange;
app.config.globalProperties.selectDictLabel = selectDictLabel;
app.config.globalProperties.selectDictLabels = selectDictLabels;

// 全局组件挂载
app.component("DictTag", DictTag);
app.component("Pagination", Pagination);
app.component("TreeSelect", TreeSelect);
app.component("FileUpload", FileUpload);
app.component("ImageUpload", ImageUpload);
app.component("ImagePreview", ImagePreview);
app.component("RightToolbar", RightToolbar);
app.use(router);
app.use(store);
app.use(plugins);
app.use(elementIcons);
app.use(VForm3);
app.use(VueVideoPlayer);

app.component("svg-icon", SvgIcon);

directive(app);
console.dir(ElementPlus);
// ElementPlus.TableColumn.props.showOverflowTooltip = {
//   type: Boolean,
//   default: true,
// };
// 使用element-plus 并且设置全局的大小
app.use(ElementPlus, {
  locale: locale,
  // 支持 large、default、small
  size: Cookies.get("size") || "default",
});

app.mount("#app");
